草庐IT

java - 在 Java 中解析 CSV

全部标签

ruby-on-rails - 如何将 ActiveRecord 模型数组转换为 CSV?

我有一组ActiveRecord模型,我希望将其转换为CSV。我尝试研究像FasterCSV这样的gem,但它们似乎只适用于字符串和数组,而不适用于ActiveRecord模型。简而言之,我要转换:user1=User.firstuser2=User.lasta=[user1,user2]收件人:id,username,bio,email1,user1,user1bio,user1email1,user2,user2bio,user2email有没有简单的Rails方法可以做到这一点? 最佳答案 下面将所有用户的属性写入一个文件:C

ruby - 解析 Ruby 脚本中的命令行参数

我想从命令行调用Ruby脚本,并传入键/值对参数。命令行调用:$rubymy_script.rb--first_name=donald--last_name=knuth我的脚本.rb:putsargs.first_name+args.last_name执行此操作的标准Ruby方法是什么?在其他语言中,我通常必须使用选项解析器。在Ruby中,我看到我们有ARGF.read,但这似乎无法像本例中的键/值对那样工作。OptionParser看起来很有希望,但我不知道它是否真的支持这种情况。 最佳答案 Ruby的内置OptionParser

Ruby CSV - 获取当前行/行号

我正在尝试弄清楚如何从RubyCSV中获取当前行/行号。这是我的代码:options={:encoding=>'UTF-8',:skip_blanks=>true}CSV.foreach("data.csv",options,)do|row,i|putsiend但这似乎并没有按预期工作。有办法做到这一点吗? 最佳答案 由于当前Rubies中CSV的更改,我们需要进行一些更改。在2.6之前使用Ruby的原始解决方案的答案中进一步查看。以及with_index的使用,无论版本如何,它都可以继续工作。对于2.6+这将有效:require'

ruby - 使用 Ruby CSV 更改导出的 CSV 中的字段分隔符/定界符

是否可以将默认字段分隔符从逗号更改为其他字符,例如用于导出的'|'? 最佳答案 下面是一个使用选项卡的示例。到一个文件:CSV.open("myfile.csv","w",{:col_sep=>"\t"})do|csv|csv到一个字符串:csv_string=CSV.generate(:col_sep=>"\t")do|csv|csv这是关于CSV的当前文档:http://ruby-doc.org/stdlib/libdoc/csv/rdoc/index.html 关于ruby-使用R

Ruby 将 CSV 文件读取为 UTF-8 和/或将 ASCII-8Bit 编码转换为 UTF-8

我正在使用ruby1.9.2我正在尝试解析包含一些法语单词(例如spécifié)的CSV文件,并将内容放入MySQL数据库中。当我从CSV文件中读取行时,file_contents=CSV.read("csvfile.csv",col_sep:"$")返回的元素是ASCII-8BIT编码的字符串(spécifié变为sp\xE9cifi\xE9),然后像“spécifié”这样的字符串没有正确保存到我的MySQL数据库中。YehudaKatz表示ASCII-8BIT实际上是“二进制”数据,这意味着CSV不知道如何读取适当的编码。所以,如果我尝试让CSV强制编码如下:file_cont

ruby - 导入csv数据时,如何去掉 "invalid byte sequence in UTF-8"

我们允许用户通过csv导入数据(使用ruby​​1.9.2,因此它是更快的csv)。作为用户数据,当然,它可能没有得到适当的清理。当我们尝试在/index方法中显示数据时,我们有时会收到错误“UTF-8中的无效字节序列”,指向我们显示字段widget.name之一的erb当我们进行导入时,我们希望强制传入的数据有效...是否有一个ruby​​运算符可以将字符串映射到有效的utf8字符串,例如,类似goodstring=badstring.no_more_invalid_bytes“坏”数据的一个示例是char,它看起来像连字符,但不是常规的ascii连字符。我们更愿意将非utf-8字符

ruby - 在 Ruby 中解析制表符分隔文件的最佳方法是什么?

在Ruby中解析制表符分隔文件的最佳(最有效)方法是什么? 最佳答案 RubyCSV库允许您指定字段分隔符。Ruby1.9使用FasterCSV.这样的事情会起作用:require"csv"parsed_file=CSV.read("path-to-file.csv",col_sep:"\t") 关于ruby-在Ruby中解析制表符分隔文件的最佳方法是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c

ruby - 解析包含标题字段作为每行属性的 CSV 文件

我想解析一个CSV文件,以便每一行都被视为一个对象,标题行是对象中属性的名称。我可以写这个,但我确定它已经在那里了。这是我的CSV输入:"foo","bar","baz"1,2,3"blah",7,"blam"4,5,6代码看起来像这样:CSV.open('my_file.csv','r')do|csv_obj|putscsv_obj.foo#prints1the1sttime,"blah"2ndtime,etcputscsv.bar#prints2thefirsttime,7the2ndtime,etcend使用Ruby的CSV模块,我相信我只能通过索引访问字段。我认为上面的代码会更

ruby DateTime 从 'mm/dd/yyyy' 格式解析

我正在使用ruby1.9.3并希望从'mm/dd/yyyy'日期获取Date或Time对象格式字符串Time.zone.parse("12/22/2011")这是给我***ArgumentErrorException:argumentoutofrange 最佳答案 require'date'my_date=Date.strptime("12/22/2011","%m/%d/%Y") 关于rubyDateTime从'mm/dd/yyyy'格式解析,我们在StackOverflow上找到一个

ruby-on-rails - 解析字符串以添加到 URL 编码的 URL

给定字符串:"Hellothereworld"如何创建这样的URL编码字符串:"Hello%20there%20world"我还想知道如果字符串也有其他符号该怎么办,比如:"hellothere:world,howareyou"最简单的方法是什么?我打算解析然后为此构建一些代码。 最佳答案 在2019年,URI.encode已过时,不应再使用。require'uri'URI.encode("Hellothereworld")#=>"Hello%20there%20world"URI.encode("hellothere:world,